<!-- 短信登录 - smsLogin  -->
<template>
  <view class="ss-p-y-20">
    <!-- 标题栏 -->
    <view class="head-box ss-m-b-60">
      <view
        class="ss-flex ss-m-b-20"
        style="flex-direction: row;"
      >
        <view
          class="head-title-active ss-m-r-40"
          @tap="showAuthModal('accountLogin')"
        >账号登录</view>
        <view class="head-title head-title-line head-title-animation">短信登录</view>
      </view>
      <view class="head-subtitle">未注册手机号请先点击下方立即注册</view>
    </view>

    <!-- 表单项 -->
    <uni-forms
      ref="smsLoginRef"
      v-model="state.model"
      :rules="state.rules"
      validateTrigger="bind"
      labelWidth="140"
      labelAlign="center"
    >
      <uni-forms-item
        name="mobile"
        label="手机号"
      >
        <uni-easyinput
          placeholder="请输入手机号"
          v-model="state.model.mobile"
          :inputBorder="false"
          type="number"
        >
          <template v-slot:right>
            <button
              class="ss-reset-button code-btn code-btn-start"
              :disabled="state.isMobileEnd"
              :class="{ 'code-btn-end': state.isMobileEnd }"
              @tap="getSmsCode('smsLogin', state.model.mobile)"
            >
              {{ getSmsTimer('smsLogin') }}
            </button>
          </template>
        </uni-easyinput>
      </uni-forms-item>

      <uni-forms-item
        name="code"
        label="验证码"
      >
        <uni-easyinput
          placeholder="请输入验证码"
          v-model="state.model.code"
          :inputBorder="false"
          type="number"
          maxlength="4"
        >
          <template v-slot:right>
            <button
              class="ss-reset-button login-btn-start"
              :class="[props.radioShow ? 'login-btn-end' : '']"
              @tap="smsLoginSubmit"
            > 登录 </button>
          </template>
        </uni-easyinput>
      </uni-forms-item>
    </uni-forms>

    <button
      class="ss-reset-button type-btn"
      @tap="showAuthModal('smsRegister')"
    > 立即注册 </button>
  </view>
</template>

<script setup>
import { computed, watch, ref, reactive, unref } from 'vue';
import sheep from '@/sheep';
import { code, mobile } from '@/sheep/validate/form';
import { showAuthModal, closeAuthModal, getSmsCode, getSmsTimer } from '@/sheep/hooks/useModal';
import throttle from '@/sheep/helper/throttle';

const smsLoginRef = ref(null);

const props = defineProps({
  agreeStatus: {
    type: Boolean,
    default: false,
  },
  radioShow: {
    type: Boolean,
    default: false,
  }
});

// 数据
const state = reactive({
  isMobileEnd: false, // 手机号输入完毕
  codeText: '获取验证码',
  model: {
    mobile: '', // 手机号
    code: '', // 验证码
  },
  rules: {
    code,
    mobile,
  },
});

// 2.短信登录
async function smsLoginSubmit () {
  const validate = await unref(smsLoginRef)
    .validate()
    .catch((error) => {
      console.log('error: ', error);
    });
  if (!validate) return;

  if (!props.agreeStatus) {
    sheep.$helper.toast('请勾选同意');
    return;
  }
  const { error } = await sheep.$api.user.smsLogin(state.model);
  if (error === 0) {
    closeAuthModal();
  }
}
</script>

<style lang="scss" scoped>
@import '../index.scss';
</style>
